<!DOCTYPE html>
<html lang="zh-CN"
      xmlns="http://www.w3.org/1999/xhtml"
      xmlns:th="http://www.thymeleaf.org"
      xmlns:layout="http://www.ultraq.net.nz/thymeleaf/layout"
      xmlns:shiro="http://www.pollix.at/thymeleaf/shiro"
      layout:decorator="model/boardModel">
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
    <script th:src="@{/plugins/area/ProJson.js}"></script>
    <title>省总商政管理</title>
    <style type="text/css">
        .modal-dialog {
            position: absolute;
            top: 0;
            bottom: 0;
            left: 0;
            right: 0;
        }
    </style>
</head>
<body>

<div th:fragment="pagenav" th:remove="tag">
    <div th:replace="model/nav :: pageheader ('省总商政管理','省总商政管理')"></div>
</div>

<div th:fragment="content" th:remove="tag">


    <div class="row">
        <div class="col-xs-12">

            <div class="box box-primary">
                <div class="box-header with-border">
                    <h3 class="box-title">查询条件</h3>
                    <div class="box-tools pull-right">
                        <button class="btn btn-box-tool" data-widget="collapse"><i class="fa fa-minus"></i></button>
                    </div>
                </div>
                <!-- /.box-header -->
                <!-- form start -->
                <form id="queryForm" th:action="@{/agency/list}" method="post">
                    <div class="box-body">
                        <div class="row">

                            <div class="col-xs-3">
                                <input type="text" th:name="agencyName" class="form-control input-sm" placeholder="省总商政名称"/>
                            </div>
                            <div class="col-xs-3">
                                <input type="text" th:name="contactName" class="form-control input-sm" placeholder="联系人"/>
                            </div>
                            <div class="col-xs-3">
                                <input type="text" th:name="contactPhone" class="form-control input-sm" placeholder="联系电话"/>
                            </div>
                            <div class="col-xs-3">
                                <shiro:hasRole name="sys_supervisor">
                                    <input type="hidden" th:name="userId" th:value="${session.authUser.userId}"/>
                                </shiro:hasRole>
                                <shiro:hasRole name="sys_nationwide">
                                    <input type="hidden" th:name="nationwideId" th:value="${session.authUser.userId}"/>
                                </shiro:hasRole>
                                <button id="btn-query" type="button" class="btn btn-primary pull-right btn-sm">查询
                                </button>
                            </div>
                        </div>
                    </div>
                    <!-- /.box-body -->

                    <div class="box-footer">

                    </div>
                </form>
            </div>


            <div class="box">
                <div class="box-body">
                    <div class="table-responsive">
                    <table id="dataTable" class="table table-striped table-bordered table-hover table-condensed">

                        <thead>
                        <tr>
                            <th>省总商政名称</th>
                            <th>联系人名称</th>
                            <th>联系电话</th>
                            <th>负责区域</th>
                            <th>创建时间</th>
                            <shiro:hasRole name="sys_nationwide">
                            <th>操作</th>
                            </shiro:hasRole>
                        </tr>
                        </thead>
                    </table>
                    </div>
                </div>
            </div>
        </div>

    </div>


    <!-- confModal -->
    <div class="modal fade" id="confModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" data-backdrop="static"
         aria-hidden="true">
        <div class="modal-dialog">
            <div class="modal-content">

                <div class="modal-header" style="background-color: #307095;">
                    <button type="button" class="close" data-dismiss="modal">
                        <span aria-hidden="true">&times;</span><span class="sr-only">关闭</span>
                    </button>
                    <h4 class="modal-title">状态</h4>
                </div>

                <div class="modal-body">
                    <form class="form-horizontal" id="confForm" action="/pro" method="post">
                        <input type="hidden" id="pro-roleId" class="form-control" name="roleId"/>
                        <div id="tree"></div>
                    </form>
                </div>
                <!-- modal-body END -->

                <div class="modal-footer">
                    <button type="submit" id="btn-prof" class="btn btn-primary">授权</button>
                </div>
            </div>
        </div>
    </div>

    <!-- EditUser -->
    <div class="modal fade" id="editModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" data-backdrop="static"
         aria-hidden="true">
        <div class="modal-dialog">
            <div class="modal-content">

                <div class="modal-header" style="background-color: #307095;">
                    <button type="button" class="close" data-dismiss="modal">
                        <span aria-hidden="true">&times;</span><span class="sr-only">关闭</span>
                    </button>
                    <h4 class="modal-title" id="myModalLabel2">信息-编辑</h4>
                </div>

                <div class="modal-body">
                    <form class="form-horizontal" id="editForm" action="/agency/edit" method="post">
                        <input type="hidden" class="form-control" name="agencyId"/>
                        <div class="form-group">
                            <label class="col-sm-3 control-label">省总商政名称</label>
                            <div class="col-sm-9">
                                <input type="text" class="form-control" name="agencyName"
                                       data-rule-required="true" data-msg-required="请录入省总商政名称"
                                       data-rule-minlength="2" data-msg-minlength="省总商政名称最少2个字符"
                                       data-rule-maxlength="20" data-msg-maxlength="省总商政名称最大为20个字符"
                                       placeholder="省总商政名称"/>
                            </div>
                        </div>
                        <div class="form-group">
                            <label  class="col-sm-3 control-label">登陆账户名</label>
                            <div class="col-sm-9">
                                <input type="text" class="form-control" id="loginName" name="loginName"
                                       data-rule-required="true" data-msg-required="请录入管理账户名"
                                       data-rule-minlength="2" data-msg-minlength="管理账户名最少2个字符"
                                       data-rule-maxlength="20" data-msg-maxlength="管理账户名最大为20个字符"
                                       data-rule-commonString ="true" data_msg-commonString="账户名格式为字母或字母加数字"
                                       placeholder="登陆后台管理的账户名，请牢记！"/>
                            </div>
                        </div>
                        <div class="form-group">
                            <label class="col-sm-3 control-label">联系人</label>
                            <div class="col-sm-9">
                                <input type="text" class="form-control" name="contactName"
                                       data-rule-required="true" data-msg-required="请录入联系人"
                                       data-rule-minlength="2" data-msg-minlength="联系人最少2个字符"
                                       data-rule-maxlength="20" data-msg-maxlength="用户名最大为20个字符"
                                       placeholder="联系人"/>
                            </div>
                        </div>
                        <div class="form-group">
                            <label class="col-sm-3 control-label">手机号</label>
                            <div class="col-sm-9">
                                <input type="text" class="form-control" name="contactPhone"
                                       data-rule-required="true" data-msg-required="请录入手机号"
                                       data-rule-iphone="true"
                                       placeholder="手机号"/>
                            </div>
                        </div>
                        <div class="form-group">
                            <label  class="col-sm-3 control-label">所属大区</label>
                            <div class="col-sm-9">
                                <select class="form-control select2" name="supervisorId" id="supervisorId" data-rule-required="true" data-msg-required="请选择所属大区">
                                </select>
                            </div>
                        </div>
                        <div class="form-group">
                            <label class="col-sm-3 control-label">负责地区</label>
                            <div class="col-sm-9">
                                <select id="selProvince" name="provinceId" style="width: 160px;height: 34px;float:left" data-rule-required="true" data-msg-required="请选择地区" class="form-control select2" >
                                    <option value="0">--省份--</option>
                                </select>
                                <input type="hidden" name="provinceName" id="provinceName" value=""/>
                            </div>
                        </div>
                        <shiro:hasRole name="sys_nationwide">
                            <input type="hidden" id="nationwideId" th:name="nationwideId" th:value="${session.authUser.userId}"/>
                        </shiro:hasRole>

                    </form>
                </div>
                <!-- modal-body END -->

                <div class="modal-footer">
                    <button type="submit" id="btn-submit" class="btn btn-primary">提交</button>
                </div>
            </div>
        </div>
    </div>

    <script>

        $(function () {
            var tables = $("#dataTable").dataTable({
                serverSide: true,//分页，取数据等等的都放到服务端去
                processing: true,//载入数据的时候是否显示“载入中”
                pageLength: 10,  //首次加载的数据条数
                ordering: false,//排序操作在服务端进行，所以可以关了。
                pagingType: "full_numbers",
                autoWidth: false,
                stateSave: true,//保持翻页状态，和tables.fnDraw(false);结合使用
                searching: false,
                ajax: {   //类似jquery的ajax参数，基本都可以用。
                    type: "post",//后台指定了方式，默认get，外加datatable默认构造的参数很长，有可能超过get的最大长度。
                    url: "/agency/list",
                    dataSrc: "data",//默认data，也可以写其他的，格式化table的时候取里面的数据
                    data: function (d) {//d是原始的发送给服务器的数据，默认很长。
                        var param = {}; //因为服务端排序，可以新建一个参数对象
                        param.draw = d.draw;
                        param.start = d.start;
                        param.length = d.length;
                        var formData = $("#queryForm").serializeArray();//把form里面的数据序列化成数组
                        formData.forEach(function (e) {
                            param[e.name] = e.value;
                        });
                        return param;//自定义需要传递的参数。
                    }
                },
                columns: [//对应上面thead里面的序列
                    {"data": 'agencyName', defaultContent: ""},
                    {"data": 'contactName', defaultContent: ""}, //mData 表示发请求时候本列的列明，返回的数据中相同下标名字的数据会填充到这一列
                    {"data": 'contactPhone', defaultContent: ""},
                    {"data": 'provinceName', defaultContent: ""},
                    {"data": 'createTimeStr', defaultContent: ""},
                <shiro:hasRole name="sys_nationwide">
                    {"data": null, "width": "200px"}
                    </shiro:hasRole>
                ],

                /*<![CDATA[*/
                columnDefs: [
                    {
                        targets: -1,//编辑
                        data: null,//下面这行，添加了编辑按钮和，删除按钮
                        defaultContent: "<div class='btn-group'><button id='editRow' class='btn btn-primary btn-sm' type='button'><i class='fa fa-edit'></i>编辑</button>" +
                        "<button id='delRow' class='btn btn-primary btn-sm' type='button'><i class='fa fa-trash-o'></i>删除</button></div>"+
                        "<div class='btn-group'><button id='changePass' class='btn btn-primary btn-sm' type='button'><i class='fa fa-edit'></i>重置密码</button>"
                    }
                ],
                dom: '<"toolbar">frtip',
                /*]]>*/

                //每加载完一行的回调函数
                createdRow: function (row, data, index) {
                    //修改单元格样式
                    //$('td', row).eq(5).css('font-weight',"bold").css("color","red");//获取到具体行具体格的元素
                },
                initComplete: function (setting, json) {
                    //初始化完成之后替换原先的搜索框。
                },
                //在每次table被draw完后调用
//                fnDrawCallback: function () {
//                    var api = this.api();
//                    //获取到本页开始的条数
//                    var startIndex = api.context[0]._iDisplayStart;
//                    api.column(0).nodes().each(function (cell, i) {
//                        cell.innerHTML = startIndex + i + 1;
//                    });
//                },


                language: {
                    lengthMenu: "",//不显示记录条数选择
                    //lengthMenu: '<select class="form-control input-xsmall">' + '<option value="5">5</option>' + '<option value="10">10</option>' + '<option value="20">20</option>' + '<option value="30">30</option>' + '<option value="40">40</option>' + '<option value="50">50</option>' + '</select>条记录',//左上角的分页大小显示。
                    processing: "加载中",//处理页面数据的时候的显示
                    /*<![CDATA[*/
                    paginate: {//分页的样式文本内容。
                        previous: "<",
                        next: ">",
                        first: "<<",
                        last: ">>"
                    },
                    /*]]>*/
                    zeroRecords: "没有数据",//table tbody内容为空时，tbody的内容。
                    //下面三者构成了总体的左下角的内容。
                    //info: "共 _PAGES_ 页，显示第 _START_ 到第 _END_ 条 ",//筛选之后得到 _TOTAL_ 条，初始 _MAX_ 条   左下角的信息显示，大写的词为关键字。
                    info: "共 _PAGES_ 页，显示第 _START_ 到第 _END_ 条",
                    infoEmpty: "0条记录",//筛选为空时左下角的显示。0条记录
                    infoFiltered: "",//筛选之后的左下角筛选提示(另一个是分页信息显示，在上面的info中已经设置，所以可以不显示)，
                    sSearch: "关键字："
                }

            });

            <shiro:hasRole name="sys_nationwide">
            $("div.toolbar").html('<button type="button" class="btn btn-primary btn-sm" id="btn-add">新增</button>');

          </shiro:hasRole>

            //查询按钮
            $("#btn-query").on("click", function () {
                tables.fnDraw();
            });
            var url = "/agency/add";
            //添加
            $("#btn-add").on("click", function () {
                url = "/agency/add";
                $("#editForm div").removeClass('has-success');
                $("#editModal input[name=agencyName]").val("");
                $("#editModal input[name=contactName]").val("");
                $("#editModal input[name=loginName]").val("");
                $("#editModal input[name=loginName]").attr("readonly",false);
                $("#editModal input[name=contactPhone]").val("");
                $("#selProvince").val("0");
                $("#myModalLabel2").text("城市经理-新增");
                $("#editModal").modal("show");
                //获取大区
                $.ajax({
                url: '/agency/getRegions',
                data:{"nationwideId":$("#nationwideId").val()},
                type: 'POST',
                dataType: "json",
                cache: "false",
                success: function (result) {
                    if (result.result == 200) {
                        /*<![CDATA[*/
                        $("#supervisorId").append("<option value='' ></option>");
                        /*]]>*/
                        $.each(result.data, function (i, n) {
                            /*<![CDATA[*/
                            $("#supervisorId").append("<option value='" + n.supervisorId + "'>" + n.supervisorName + "</option>")
                            /*]]>*/
                        });
                    }else{
                        toastr.error(result.msg);
                        return;
                    }
                },
                error:function(err){
                    toastr.error("网络错误...");
                }
            });
            $("#myModalLabel2").text("代理-新增");
            $("#editModal").modal("show");

        });
            $('#editModal').on('hide.bs.modal', function () {
                $("#editModal input[name=loginName]").attr("readonly",false);
                $("#supervisorId > option").remove();
            });
            //修改
            $("#dataTable tbody").on("click", "#editRow", function () {
                var data = tables.api().row($(this).parents("tr")).data();
                $("#editForm div").removeClass('has-success');
                $("#editModal input[name=agencyId]").val(data.agencyId);
                $("#editModal input[name=loginName]").val(data.loginName);
                $("#editModal input[name=loginName]").attr("readonly",true);
                $("#editModal input[name=agencyName]").val(data.agencyName);
                $("#editModal input[name=agencyName]").val(data.agencyName);
                $("#editModal input[name=contactName]").val(data.contactName);
                $("#editModal input[name=contactPhone]").val(data.contactPhone);
                //获取大区
                $.ajax({
                    url: '/agency/getRegions',
                    data:{"nationwideId":$("#nationwideId").val()},
                    type: 'POST',
                    dataType: "json",
                    cache: "false",
                    success: function (result) {
                        if (result.result == 200) {
                            /*<![CDATA[*/
                            $("#supervisorId").append("<option value='' ></option>");
                            /*]]>*/
                            $.each(result.data, function (i, n) {
                                /*<![CDATA[*/
                                if(data.supervisorId==n.supervisorId){
                                    $("#supervisorId").append("<option value='" + n.supervisorId + "' selected='selected'>" + n.supervisorName + "</option>")
                                }else{
                                    $("#supervisorId").append("<option value='" + n.supervisorId + "' >" + n.supervisorName + "</option>")
                                }
                                /*]]>*/
                            });
                        }else{
                            toastr.error(result.msg);
                            return;
                        }
                    },
                    error:function(err){
                        toastr.error("网络错误...");
                    }
                });
                /*<![CDATA[*/
                $.each(province, function (k, p) {
                    if (data.provinceId == p.ProID) {
                        var option = "<option value='" + p.ProID + "' selected='selected'>" + p.ProName + "</option>";
                        $("#selProvince ").append(option);
                    }else{
                        var option = "<option value='" + p.ProID + "'>" + p.ProName + "</option>";
                        $("#selProvince ").append(option);
                    }
                });
                /*]]>*/
                url = "/agency/edit";

                $("#editModal").modal("show");
            });
            $("#dataTable tbody").on("click", "#changePass", function () {
                var data = tables.api().row($(this).parents("tr")).data();
                $("#changePass").attr("disabled",true);
                $.ajax({
                    cache: false,
                    type: "POST",
                    url: "/agency/changePass",
                    data: {"agencyId":data.agencyId},
                    dataType: "json",
                    async: false,
                    error: function (request) {
                        $("#changePass").attr("disabled",false);
                        toastr.error("网络错误...");
                    },
                    success: function (data) {
                        if (data.result == "200") {
                            toastr.success(data.msg);
                            $("#changePass").attr("disabled",false);
                        } else {
                            $("#changePass").attr("disabled",false);
                            toastr.error(data.msg);
                        }
                    }
                });
            })
            var validater = $("#editForm").validate();
            //添加、修改  表单异步提交
            $("#btn-submit").on("click", function () {
                if(validater.form()) {
                   $("#provinceName").val($("#selProvince").find("option:selected").text());
                    $("#btn-submit").attr("disabled",true);
                    $.ajax({
                        cache: false,
                        type: "POST",
                        url: url,
                        data: $("#editForm").serialize(),
                        dataType: "json",
                        async: false,
                        error: function (request) {
                            toastr.error("网络错误...");
                        },
                        success: function (data) {
                            //   data = $.parseJSON(data);
                            if (data.result == "200") {
                                $("#btn-submit").attr("disabled",false);
                                $("#editModal").modal("hide");
                                tables.fnDraw();
                                toastr.success(data.msg);
                            } else {
                                $("#btn-submit").attr("disabled",false);
                                toastr.error(data.msg);
                            }
                        }
                    });
                }
            });

            //删除
            $("#dataTable tbody").on("click", "#delRow", function () {
                var data = tables.api().row($(this).parents("tr")).data();
                bootbox.confirm(
                    {
                        message: "确认要删除吗",
                        buttons: {
                            confirm: {
                                label: '确认'
                            },
                            cancel: {
                                label: '取消'
                            }
                        },
                        callback: function (result) {
                            // 返回 true  或者false
                            if (result) {
                                $.ajax({
                                    url: '/agency/del/' + data.agencyId,
                                    type: 'POST',
                                    dataType: "json",
                                    cache: "false",
                                    success: function (result) {
                                        if (result.result == 200) {
                                            toastr.success(result.msg);
                                            tables.api().row().remove().draw(false);
                                        } else {
                                            toastr.error(result.msg);
                                        }
                                    },
                                    error: function (err) {
                                        toastr.error("网络错误...");
                                    }
                                });
                            }
                        }
                    });


            });

            /*<![CDATA[*/
            $.each(province, function (k, p) {
                var option = "<option value='" + p.ProID + "'>" + p.ProName + "</option>";
                $("#selProvince").append(option);
            });

            /*]]>*/

        });
    </script>


</div>


</body>
</html>